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(54) Storage subsystem and storage controller 

(57) A storage subsystem and a storage controller 
adapted to take advantage of high data transfer rates of 
fibre channels while offering enhanced reliability and 
availability and capable of connecting with a plurality of 
host computers having multiple different interfaces. A 
loop is provided to serve as a common loop channel 
having fibre channel interfaces. Host interface control- 
lers (HIFC) connected to host computers haying differ- 



ent interfaces permit conversion between the fibre chan- 
nel interface and a different interface as needed. Control 
processors, shared by the host interface controllers, 
each reference FCAL (fibre channel arbitrated loop) 
management information to capture a frame having an 
address of the processor in question from among the 
frames passing through the loop. I/O processing is then 
carried out by the controller in accordance with a range 
of logical unit numbers (LUN) set in the captured frame. 
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Description 

BACKGROUND OF THE INVENTION 
Field of the invention 

[0001 ] The present invention relates to a storage sub- 
system and a storage controller, both connected to host 
computers. More particularly, the invention relates to a 
storage subsystem and a storage controller adapted to 
provide enhanced performance and reliability. 

Description of the Related Art 

[0002] In recent years, storage controllers have been 
required to provide better performance, higher reliability 
and greater availability than ever before as computer 
systems are getting larger in scale to process data at 
higher speeds than ever before, 24 hours a day and 365 
days a year, with data transfer interfaces also enhanced 
in speed. Illustratively, Japanese Patent Laid-open No. 
Hei 1 1 -7359 discloses a storage controller incorporating 
an internal network to improve its performance. 
[0003] There has been a growing need for connecting 
a storage controller to a plurality of host computers hav- 
ing multiple interfaces, as shown in Fig. 8. In such a stor- 
age controller a host interface section comprises a host 
interface for addressing each different host computer. A 
control processor in each host interface analyzes I/O 
commands received from the corresponding host com- 
puter and exchanges data accordingly with a cache 
memory 215 over a signal line. Japanese Patent Laid- 
open No. Hei 9-325905 illustratively discloses one such 
storage controller. 

[0004] Techniques have been known recently which 
substitute a fibre channel interface for the SCSI (Small 
Computer System Interface) between a host computer 
and a storage controller. Illustratively, Japanese Patent 
Laid-open No. Hei 10-333839 discloses techniques for 
connecting a storage controller with a host computer us- 
ing a fibre channel interface. The disclosed storage con- 
troller is designed for dedicated use with a host compu- 
ter having a fibre channel interface. 

SUMMARY OF THE INVENTION 

[0005] The techniques disclosed in the above-cited 
Japanese Patent Laid-open Nos. Hei 11-7359 and Hei 
9-325905 have one disadvantage: the storage controller 
as a whole has its performance constrained by the per- 
formance of a single control processor that handles I/O 
requests from host computers. Another disadvantage is 
that a disabled control processor will prevent host com- 
puters from using the storage controller. In particular, 
since today's fibre channels are capable of transferring 
data at speeds as high as 100 MB/S, the performance 
of the control processor can be an impediment to taking 
advantage of the high data transfer rates offered by fibre 



channels. 

[0006] The techniques disclosed in the above-cited 
Japanese Patent Laid-open No. Hei 10-333839 relate 
to a storage controller for exclusive use with fibre chan- 
5 nel interfaces. That is : the proposed storage controller 
is incapable of connecting with a host computer having 
a SCSI interface. 

[0007] It is therefore an object of the present invention 
to provide a storage subsystem and a storage controller 
10 adapted to take advantage of high data transfer rates of 
fibre channels while offering enhanced reliability and 
availability. 

[0008] It is another object of the present invention to 
provide a storage subsystem and a storage controller 

15 capable of connecting with a plurality of host computers 
having multiple different interfaces. 
[0009] In carrying out the invention and according to 
one aspect thereof , there is provided a storage subsys- 
tem or a storage controller for controlling transfer of in- 

20 put/output data to and from a lower level storage medi- 
um drive unit in response to input/output requests re- 
ceived from a higher level external entity. The storage 
subsystem or storage controller comprises: at least one 
external interface controller for receiving the input/out- 

25 put requests from the higher level external entity in ac- 
cordance with a type of interface with the higher level 
external entity; at least one control processor which 
processes the input/output requests; and a loop of fibre 
channel interfaces interposed between the external in- 

30 terface controller and the control processor so as to 
serve as a channel through which information is trans- 
ferred therebetween. 

[001 0] In a preferred structure according to the inven- 
tion, the interface of the external interface controller in- 

35 terracing to the higher level external entity may be a fibre 
channel interface. In another preferred structure accord- 
ing to the invention, the external interface controller may 
be capable of interface conversion between an interface 
which interfaces to the higher order external entity and 

to which is different from a fibre channel interface on the 
one hand, and a fibre channel interface on the other 
hand. 

[0011] Other objects, features and advantages of the 
invention will become more apparent upon a reading of 
^5 the following description and appended drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 
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[0012] 



Fig. 1 is a block diagram of a storage subsystem 
practiced as an embodiment of the invention; 
Fig. 2 is a block diagram of a loop 133 in the em- 
bodiment and related facilities; 
Fig. 3 is a table showing a data structure of FCAL 
management information 113 for use with the em- 
bodiment; 

Fig. 4 is a flowchart of steps performed by control 
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processors 114 through 1i7 of the embodiment; 
Fig. 5 is a table depicting an example of FCAL man- 
agement information 113 updated when control 
processors stopped; 

Fig. 6 is a table indicating an example of FCAL man- 
agement information 113 updated when an imbal- 
ance of control processor loads was detected; 
Fig. 7 is a table showing another example of FCAL 
management information 113 updated when an im- 
balance of control processor loads was detected; 
and 

Fig. 8 is a block diagram of a conventional storage 
controller. 

DESCRIPTION OF THE PREFERRED 
EMBODIMENTS 

[0013] Preferred embodiments of this invention will 
now be described with reference to the accompanying 
drawings. 

[0014] Fig. 1 is a block diagram of a system compris- 
ing a disk subsystem typically embodying the invention . 
A disk controller 107 is connected to host computers 
1 00, 1 01 and 1 02 on the higher level side. The host com- 
puter 101 is a mainframe computer connected to the 
disk controller 107 through a mainframe channel. The 
host computer 100 is an open system computer con- 
nected to the disk controller 1 07 through a fibre channel 
interface. The host computer 102 is another open sys- 
tem computer connected to the disk controller 1 07 via 
a SCSI (Small Computer System Interface). The disk 
controller 107 is connected via loops 125 and 126 of fi- 
bre channel interfaces to drives 127, 128, 129 and 130 
on the lower level side. 

[0015] Host interface controllers (HI FC) 103, 104 and 
105 are connected to the host computers 100, 101 and 
1 02 respectively, as well as to a loop 1 33 of fibre channel 
interfaces . Control processors 1 1 4, 1 1 5, 1 1 6 and 117 are 
connected to the loop 1 33 on the one hand and to a com- 
mon bus 118 on the other hand. The common bus 118 
is connected not only to the controller processors 114 
through 1 1 7 but also to a shared control memory 1 1 2, a 
cache memory 122, and control processors 119 and 
120. The control processors 11 9 and 120 are connected 
via fibre channels 141 to drive interface controllers 
(DIFC) 123 and 124. The DIFCs 123 and 124 are con- 
nected to the drives 1 27, 1 28, 1 29 and 1 30 through the 
loops 125 and 126, The control processors 114, 115, 
1 1 6 and 1 1 7 are connected to a service processor 1 31 
by way of a signal line 132. 

[0016] The HIFC 103 is an interface controller inter- 
facing to a higher level external entity. Upon receipt of 
I/O commands, data and control information in the form 
of frames from the host computer 100, the HIFC 103 
forwards what is received unmodified to one of the con- 
trol processors 114 through 117 through the loop 133. 
On receiving data and control information in frames from 
any of the control processors 114 through 117 via the 
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loop 133, the HIFC 1 03 transfers the data and informa- 
tion unmodified to the host computer 1 00. The HIFC 1 04 
. converts channel commands, data and control informa- 
tion received from the host computer 1 01 into fibre chan- 
5 nel frame format for transfer to one of the control proc- 
essors 11 4 . through 117 via the loop 133. Upon receipt 
of data and control information in frames from any of the 
control processors 1 1 4 through 1 1 7, the H IFC 1 04 con- 
verts the received data and information into a data for- 
10 mat compatible with a mainframe channel interface be- 
fore transferring what is converted to the host computer 
101. The HIFC 105 converts I/O commands, data and 
control information received from the host computer 1 02 
into fibre channel frame format for transfer to one of the 
15 control processors 114through 117. The HIFC .105 re- 
ceives data and control information in frames from any 
of the control processors 1 1 4 through 1 1 7, and converts 
the received data and information into SCS (compatible 
data format for transfer to the host computer 102. It is 
2Q possible to connect a plurality of host computers 100, 
101, 102, etc., to each of the HIFCs 103, 104 and 105. 
[0017] The cache memory 122 may be accessed by 
all control processors 114 through 117, 119 and 1 20 via 
a bus interface of the common bus 118. When in use, 
25 the cache memory 1 22 temporarily accommodates data 
sent from the host computers 100 through 102 as well 
as data retrieved from the drives 1 27 through 130. The 
data in the cache memory 122 are divided into data 
management units called cache slots. 
30 [0018] The shared control memory 112 may be ac- 
cessed by all control processors 114 through 117, 119 
and 1 20 via the common bus 1 1 8. This memory has re- 
gions permitting communication between the control 
processors, and a cache slot management table, and 
35 stores FCAL (fibre channel arbitrated loop) manage- 
ment information 113 for establishing frames to be re- 
ceived through the loop 133 by each of the control proc- 
essors 114 through 117. 

[0019] Each of the control processors 114through 117 
40 references the FCAL management information 113 in 
the shared control memory 112 to capture a frame hav- 
ing a relevant address from among the frames flowing 
through the loop 133, and executes an I/O request des- 
ignated by a received I/O command. Upon receipt of a 
45 read command, the control processor reads the re- 
quested data if any from the cache memory 122, and 
sends the retrieved data to the requesting host compu- 
ter through the loop 133 and via one of the HIFCs 103 
through 105. If the requested data are not found in the 
50 cache memory 122, the control processor in question 
sends an I/O request to the control processors 119 and 
120. Upon receipt of a write command, one of the control 
processors 114 through 117 writes target write data to 
a cache slot in the cache memory 122 and sends an I/ 
55 o request to the control processors 119 and 120. 

[0020] The control processors 119 and 1 20 receive an 
I/O request from one of the control processors 114 
through 117. If a read command is received, the control 
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processors 119 and 120 read the requested data from 
the drives 127 through 130 and write the retrieved data 
to a cache slot in the cache memory 1 22. In the case of 
a write command, the control processors 119 and 120 
write the relevant data from the cache memory 122 to 
the drives 127 through 130. 

[0021] Fig. 2 is a block diagram of the loop 133 inter- 
posed between the HjFCs 103 through 106 on the one 
hand and the control processors 1 1 4 through 1 1 7 on the 
other hand, along with facilities associated with the loop 
133. 

[0022] The loop 133 has port bypass circuits (PBC) 
108, 109, 110 and 111 constituting what is known as a 
hub structure. The PBCs 108 through 111 are a one- 
input n-output electronic switch each. As illustrated, the 
PBCs 108 through 111 are connected to the HIFCs 103 
through 106 and to the control processors 114 through 
117. 

Interconnections are provided between the PBCs 108 
and 111 as well as between the PBCs 109 and 110. In 
this embodiment, the PBCs 108 through 111 serve as a 
one-input two-output switch each. Feeding a suitable in- 
put signal to the PBC arrangement makes it possible to 
limit the number of output paths. Fiber controllers (FC) 
151 disposed upstream of the control processors 114 
through 117 recognize destination addresses of frames 
sent through the loop 1 33, capture a frame having a pre- 
determined destination address, and transfer the cap- 
tured frame to the relevant control processor connected. 
The fibre controllers 151 receive data and control infor- 
mation from the control processors 114 through 117, 
convert the received data and information into frame for- 
mat data, and forward what is converted to the loop 1 33. 
With the HIFCs 103 through 106, FCs151, and control 
processors 114 through 117 as its terminals, the loop 
1 33 constitutes a topological loop transmission channel 
called a fibre channel arbitrated loop (FCAL). A fibre 
channel communication protocol is discussed illustra- 
tively in the published ANSI manual "FIBRE CHANNEL 
PHYSICAL AND SIGNALLING (FC-PH) REV. 4.3." 
[0023] The PBC 108 is connected illustratively to the 
host computer 100 via the HIFC103. In this setup, the 
PBC 108 is connectable to the control processors 114 
and 115 as well as to the PBC 111 . This means that an 
I/O request command from the host computer 1 00 may 
be processed by the control processor 114 or 115 via 
the PBC 1 08 or by the control processor 1 1 6 or 1 1 7 via 
the PBC 111. Likewise, an I/O request command from 
the host computer 101 may be processed by the control 
processor 1 1 4 or 1 1 5 via the PBC 1 09 or by the control 
processor 11 6 or 117 via the PBC 110. 
[0024] This embodiment adopts a fibre channel inter- 
face for the fibre channels 141 as well as for the loops 
125 and 126. Thus the FCs 151, not shown, are in fact 
interposed between the control processors 1 1 9 and 1 20 
on the one hand and the fibre channels 1 41 on the other 
hand. 

[0025] Fig. 3 is a table showing a data structure of the 
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FCAL management information 113. The FCAL man- 
agement information 113 constitutes a table in which 
frames to be captured by the control processors 114 
through 1 1 7 via the loop 1 33 are set along with the range 

5 of device numbers subject to I/O processing. Entries 
making up the FCAL management information 113 in- 
clude control processor numbers 201 , AL-PAs (arbitrat- 
ed loop physical addresses) 202, and LUNs (logical unit 
numbers) 203. A control processor number 201 is an 

10 identifier of any one of the control processors 114 
through 117. An AL-PA 202 is an address assigned in 
the loop 133 to one of the control processors 114 
through 117. A LUN 203 denotes a logical device 
number or a range of logical device numbers of devices 

15 whose I/O processing is carried out by a given control 
processor. The FCAL management information 113 may 
be set or canceled as instructed by the service proces- 
sor 131 . 

[0026] Fig. 4 is a flowchart of steps performed by the 

20 control processors 114 through 117. Each of the control 
processors 114 through 117 periodically reads entries 
for the processor in question from the FCAL manage- 
ment information 113, and sets an AL-PA of the appli- 
cable processor to the connected FC 151 . In case of a 

25 change, the AL-PA is set again. The FC 151 reads AL- 
PAs in frames sent from the host computer 1 00 through 
the HIFC 103 and via the loop 133 (in step 301). If a 
given AL-PA is not found to be that of the connected 
control processor ("NO" in step 302), the processing is 

30 brought to an end. If an AL-PA is judged to be that of the 
connected control processor ("YES" in step 302), then 
the control processor in question is notified thereof. Giv- 
en the notice, the applicable control processor (one of 
the processors 1 1 4 through 1 1 7) reads the frame via the 

35 FC 151 (in step S303). A check is made to see if the 
LUN of the I/O command in the frame falls within the 
range of the LUN 203 (in step 304). If the designated 
LUN does not fall within the range of the LUN 203, an 
error response is returned to the host computer 1 00. The 

40 control processor then effects an I/O request in accord- 
ance with the received I/O command (in step 305). 
[0027] If the I/O request is a write request, the control 
processors 114 through 117 receive data from the host 
computer 100, write the received data to a suitable 

45 cache slot in the cache memory 1 22, and terminate the 
write request processing. The slot number of the cache 
slot to which to write the data is computed from an LBA 
(logical block address) attached to the data. That mem- 
ory address in the cache memory 122 which corre- 

50 sponds to the slot number is obtained from the cache 
slot management table in the shared control memory 
112. If the I/O request is a read request and if the re- 
quested data exist in the cache memory 122, the data 
are retrieved from the cache memory 122 and sent to 

55 the host computer 100 through the loop 133 and HIFC 
1 03. The presence or absence of the target data is de- 
termined by referencing the cache slot management ta- 
ble. If the requested data are not found in the cache 
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memory 122, a write request is written to an inter-proc- 
essor liaison area in the shared control memory 112. 
When the target data are judged to have been placed 
into the cache memory 122, the data are read from the 
cache memory 1 22 and sent to the host computer 1 00. 
[0028] The control processors 1 1 9 and 1 20 search the 
cache slots in the cache memory 122 for any data to be 
written to the drives 127 through 130. If such data are 
detected, they are written to the drives 1 27 through 1 30 
via the fibre channels 141, DIFGs 123 and 124, and 
loops 125 and 126. The write operation is carried out in 
a manner asynchronous with any I/O request process- 
ing between the host computer 1 00 on the one hand and 
the control processors 114 through 117 on the other 
hand. The control processors 119 and 120 convert the 
designated LUN and LBA into a physical device number 
and a physical address to determine the target drive and 
the address in the drive for the eventual write operation. 
The control processors 119 and 120 then reference the 
inter-processor liaison area in the shared control mem- 
ory 112 to see if there is any data read request. If any 
such read request is found, the relevant data are read 
from the applicable drive or drives 127 through 130 and 
written to the relevant cache slot in the cache memory 
122. Suitable entries are then updated in the cache slot 
management table to reflect the presence of the data. 
[0029] I/O requests to the drives 1 27 through 1 30 may 
be processed by any one of the control processors 119 
and 120. For example, if the control processor 119 or 
the fibre interface loop 125 has failed and is unusable, 
the processing of I/O requests is taken over by the con- 
trol processor 120 and fibre interface loop 126. If either 
of the control processors fails, I/O request processing is 
carried out without interruption of I/O operations to and 
from the drives 127 through 130. 

[0030] The control processors 114, 115, 116 and 117 
monitor one another for operation status. Specifically, 
each processor writes the current time of day to the 
shared control memory 112 at predetermined intervals. 
The times posted by each processor are checked peri- 
odically by the other control processors for an elapsed 
time. If there is no difference between the preceding and 
the current time posting, the control processor in ques- 
tion is judged to have stopped. A control processor that 
has detected the stopped processor receives manage- 
ment information about the failed processor from the 
FCAL management information 113 and takes over the 
processing of the incapacitated processor. Illustratively, 
suppose that the control processor 114 has found the 
control processor 115 stopped. In that case, the control 
processor 1 1 4 updates the FCAL management informa- 
tion 1 1 3 as shown in Fig. 5. The updates allow the con- 
trol processor 114 to take over the I/O requests regard- 
ing the LUNs 1 0-1 9 that had been processed by the con- 
trol processor 115. 

[0031] Each of the control processors 11 4 through 117 
counts the number of processed I/O requests and writes 
the counts to the shared control memory 112 at prede- 



termined intervals. The control processors reference the 
processed request counts of one another to detect proc- 
essors with inordinately high and low counts in order to 
average the counts therebetween. For example, sup : 

5 pose that the control processor 1 1 7 has found the con- 
trol processor 116 with a falling processed request count 
and the control processor 115 with a rising request 
count. In that case, the control processor 117 updates 
the FCAL management information 113 as indicated in 

10 Fig. 6. It should be noted that relevant switch settings 
of the PBCs 108 through 111 need to be changed so 
that the frame with E 8 in its AL-PA will be transmitted to 
the control processor 116 via the loop 133. The modifi- 
cations allow the control processor 116 to process I/O 

15 requests with respect to the LUNs 10-19 and 20-29, 
whereby the processed request counts are averaged 
among the control processors to permit evenly distrib- 
uted load processing. 

[0032] Part of the. LUNs 203 managed by a given con- 

20 trol processor may be taken over by another control 
processor. For example, of the LUNs 10-19 managed 
by the control processor 115, solely the LUNs 15-19 may 
be taken over by the control processor 1 1 6. In that case, 
the FCAL management information 113 is updated as 

25 shown in Fig. 7. The control processors must inform the 
host computers 100, 101 and 102 of this change be- 
cause the correspondence between the AL-PA 202 and 
LUN 203 is altered with regard to the LUNs 15-19. 
[0033] The flow of processing by the control proces- 

30 sors 114 through 117 has been described above with 
respect to the processing of I/O requests of the host 
computer 100 connected to the disk controller 107 via 
a fibre channel interface. Because the host computers 
101 and 102 are connected to the disk controller 107 

35 through interfaces different from the fibre channel inter- 
face, the HIFCs 1 04 and 1 05 convert I/O commands re- 
ceived from the host computers 101 and 102 into a 
frame format compatible with the fibre channel interface 
before sending the converted commands to the control 

40 processors 1 1 4 through 1 1 7 via the loop 1 33. These ar- 
rangements make the processing of I/O requests sent 
from the host computers 101 and 102 equivalent to that 
which has been discussed above. 
[0034] The HIFC 104 has functions for effecting con- 

45 version between commands, control information and 
data complying with an interface called ESCON (Enter- 
prise System Connection) on the one hand, and com- 
mands, control information and data pursuant to the fi- 
bre channel interface on the other hand. The HIFC 105 

50 js capable of providing conversion between commands, 
control information and data complying with the SCSI 
on the one hand, and commands, control information 
and data in keeping with the fibre channel interface on 
the other hand. When the disk controller 107 incorpo- 

55 rates HIFCs having such host interface converting func- 
tions, any host computer may be connected to the disk 
controller 1 07 regardless of the type of host interface in 
use. 
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[0035] Although the embodiment above has been 
shown involving the drives 127 through 130 as disk 
drives, this is not limitative of the invention. Alternatively, 
magnetic tape units or floppy disk drives may be con- 
nected by modifying the DIFCs 123 and 124. If the 
DIFCs are equipped with functions for effecting conver- 
sion between the SCSI and the fibre channel interface, 
the loops 125 and 1 26 may be replaced by SCSI.cables. 
[0036] The disk controller 1 07 of this embodiment al- 
lows anyone of the control processors 114 through 117 
to handle I/O requests sent from the host computer i 00. 
If a large number of I/O requests are coming from the 
host computer 1 00 depending on the data transfer rate 
between the computer 1 00 and the HI FC 1 03 or through 
the loop 133, all of the control processors 114 through 
117 can deal with the I/O requests. This provides a 
greater throughput than if fewer control processors were 
configured. Likewise, the I/O requests sent from the host 
computers 101 and 102 can be processed by any one 
of the control processors 114 through 117. When the 
host computers 100, 101 and 102 share the loop 133 
and the control processors 1 1 4 through 11 7 in the man- 
ner described, it is possible for the inventive structure 
to have less lopsided load distribution among the com- 
ponents and ensure better performance of the storage 
controller as well as better cost/performance ratio than 
if the host computers 1 00, 1 01 , 1 02, etc. , have each an 
independent host interface connected to the common 
bus as in conventional setups. 

[0037] As described, the storage controller according 
to the invention has its performance enhanced appreci- 
ably by having I/O requests from host computers proc- 
essed in parallel by a plurality of control processors even 
as the processors have their loads distributed evenly 
therebetween. The invention is particularly conducive to 
making the most of high-speed fibre channel perform- 
ance. The inventive storage controller is highly depend- 
able because if any one of the control processors fails, 
the other processors take over the processing of the in- 
capacitated processor. 

[0038] The storage controller of the invention permits 
connection of multiple host computers having a plurality 
of kinds of interfaces, with the host computers sharing 
a fibre channel loop and control processors within the 
storage controller. This feature also promises excellent 
cost/performance ratio. Moreover, the storage controller 
permits connection of drives of different kinds of storage 
media. 

[0039] As many apparently different embodiments of 
this invention may be made without departing from the 
spirit and scope thereof, it is to be understood that the 
invention is not limited to the specific embodiments 
thereof except as defined in the appended claims. 

Claims 

1 . A storage controller for controlling transfer of input/ 
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output data to and from a lower level external ap- 
paratus in response to input/output requests re- 
ceived from a higher level external apparatus, said 
storage controller comprising: 

at least one external interface controller for re- 
ceiving said input/output requests from said 
higher level external apparatus in accordance 
with a type of interface with said higher level 
external apparatus; 

at least one control processor which processes 
said input/output requests; and 
a fibre channel interface loop interposed be- 
tween said external interface controller and 
said contro I processor so as to serve as a chan- 
nel through which information is transferred 
therebetween. 

A storage controller according to claim 1 , wherein 
the interface of said external interface controller in- 
terfacing to said higher level external entity is a fibre 
channel interface. 

A storage controller according to claim 1 , wherein 
said external interface controller is capable of inter- 
face conversion between said fibre channel inter- 
face loop and an interface other than fibre channel. 

A storage controller according to claim 1 , wherein 
said fibre channel interface loop has an electronic 
switching facility which acts as a channel between 
said external interface controller and said control 
processor in response to an input signal. 

A storage subsystem for controlling transfer of in- 
put/output data to and from a lower level storage 
medium drive unit in response to input/output re- 
quests received from a higher level external appa- 
ratus, said storage subsystem comprising: 

at least one external interface controller for re- 
ceiving said input/output requests from said 
higher level external apparatus in accordance 
with a type of interface with said higher level 
external apparatus; 

at least one control processor which processes 
said input/output requests; and 
a loop of fibre channel interface interposed be- 
tween said external interface controller and 
said control processor so as to serve as a chan- 
nel through which information is transferred 
therebetween. 

A storage controller for controlling transfer of input/ 
output data to and from a lower level external ap- 
paratus in response to input/output requests re- 
ceived from a higher level external apparatus, said 
storage controller comprising: 
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a plurality of external interface controllers for 

receiving said input/output requests; 

a plurality of control processors which process 

said input/output requests; and 

a loop of fibre channel interface interposed be- 5 

tween said external interface controllers on one 

hand and said control processors on the other 

hand so as to serve as a channel through which 

information is transferred therebetween; 

wherein each of said control processors com- 10 

prises: 

frame reading means for reading a frame hav- 
ing an address of the processor in question 
from any of said input/output requests sent 
through said loop; and *s 
processing means for processing the input/out- 
put request corresponding to the frame that 
was read. 

A storage controller for controlling transfer of input/ 20 
output data to and from a lower level external ap- 
paratus in response to input/output requests re- 
ceived from a higher level external apparatus, said 
storage controller comprising: 

25 

a plurality of external interface controllers for 
receiving said input/output requests; 
a plurality of control processors which process 
said input/output requests; 

a loop of fibre channel interface interposed be- 30 
tween said external interface controllers on one 
hand and said control processors on the other 
hand so as to serve as a channel through which 
information is transferred therebetween; and 
storing means which is accessed in common 35 
by said control processors and which stores a 
logical unit number which the input/output re- 
quests are assigned to, and to be processed by 
said control processors; 

wherein each of said control processors com- *o 
prises: 

monitoring means for monitoring operating sta- 
tus of the other control processors; and 
takeover means which, if a stopped state of any 
other control processor is detected, updates 45 
said logical unit numbers in said storing means 
so that the control processor in question may 
take over the processing of the stopped control 
processor. 

50 

A storage controller according to claim 7, wherein 
said storing means stores physical addresses on 
said loop and logical unit numbers of the input/out- 
put requests to be processed with respect to each 
of said control processors, and wherein each of said ss 
control processors comprises takeover means 
which, if a stopped state of any other control proc- 
essor is detected, updates said physical addresses 
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and said logical unit numbers in said storing means 
so that the control processor in question may take 
over the processing of the stopped control proces- 
sor. 

9. A storage controller for controlling transfer of input/ 
output data to and from a lower level external ap- 
paratus in response to input/output requests re- 
ceived from a higher level external apparatus, said 
storage controller comprising: 

a plurality of external interface controllers for 
receiving said input/output requests; 
a plurality of control processors which process 
said input/output requests; 
a loop of fibre channel interface interposed be- 
tween said external interface controllers on one 
hand and said control processors on the other 
hand so as to serve as a channelthrough which 
information is transferred therebetween; and 
storing means which is accessed in common 
by said control processors and which stores 
logical unit numbers of the input/output re- 
quests to be processed by said control proces- 
sors; 

wherein each of said control processors com- 
prises: 

counting means for counting the number of 
processed input/output requests; 
notifying means for notifying the other control 
processors of the counted number of proc- 
essed input/output requests; 
acquiring means for acquiring the number of 
processed input/output requests from the other 
control processors; and 

updating means for updating said logical unit 
numbers in said storing means so as to average 
the counts of processed input/output requests 
between said control processors. 

10. A storage subsystem for controlling transfer of in- 
put/output data to and from lower level storage me- 
dium drives in response to input/output requests re- 
ceived from higher level host computers, said stor- 
age controller comprising: 

at least one external interface controller with an 
interface for receiving said input/output re- 
quests from any one of said higher level host 
computers in accordance with a type of inter- 
face with the higher level host computer in 
question; 

a cache memory for temporarily storing data; 
at least one higher level control processor 
which analyzes said input/output requests and 
which controls accordingly transfer of input/out- 
put data between said host computers on one 
hand and said cache memory on the other 
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hand; 

a loop of fibre channel interface interposed be- 
tween said external interface controller and 
said higher level control processor so as to 
serve as a channel through which information 5 
is transferred therebetween; 
at least one lower level control processor which 
controls transfer of input/output data between 
said cache memory on one hand and said stor- 
age medium drives on the other hand; and w 
a drive interface controller which is interposed 
between said lower level control processor on 
one hand and said storage medium drives on 
the other hand and which permits transfer of in- 
put/output data to and from said storage medi- 15 
um drives in accordance with a type of interface 
with the lower level drive being used. 
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